<template>
  <div>
    <div class="i-layout-page-header header-title">
      <span class="ivu-page-header-title mr20">{{ $route.meta.title }}</span>
      <div>
        <div style="float: right">
          <el-button class="bnt" type="primary" v-db-click @click="submit">保存</el-button>
        </div>
      </div>
    </div>
    <el-card :bordered="false" shadow="never" class="ivu-mt p20 h100">
      <div class="acea-row">
        <div
          class="tab_color"
          v-for="(item, index) in tabList"
          :key="index"
          :class="current === index + 1 ? 'active' : ''"
          v-db-click @click="selected(index)"
        >
          <div class="color_cont flex align-center">
            <div class="main_c mr-2" :class="item.class">
              <span class="iconfont iconxuanzhong6" v-show="current == index + 1"></span>
            </div>
            <div style="line-height: 24px">{{ item.tit }}</div>
          </div>
        </div>
      </div>
      <div class="acea-row row-top">
        <div class="pictrue" v-for="(item, index) in picList" :key="index">
          <img :src="item.image" />
        </div>
      </div>
    </el-card>
    <!--<div class="footer acea-row row-center-wrapper">-->
    <!--<el-button type="primary" v-db-click @click="submit">保存</el-button>-->
    <!--</div>-->
  </div>
</template>

<script>
import { mapState } from 'vuex';
import { colorChange, getColorChange } from '@/api/diy';
export default {
  name: 'themeStyle',
  data() {
    return {
      grid: {
        xl: 7,
        lg: 7,
        md: 12,
        sm: 24,
        xs: 24,
      },
      tabList: [
        { tit: '天空蓝', class: 'blue' },
        { tit: '生鲜绿', class: 'green' },
        { tit: '热情红', class: 'red' },
        { tit: '魅力粉', class: 'pink' },
        { tit: '活力橙', class: 'orange' },
      ],
      picList: [],
      picListBule: [{ image: require('@/assets/images/bule.jpg') }],
      picListGreen: [{ image: require('@/assets/images/green.jpg') }],
      picListRed: [{ image: require('@/assets/images/red.jpg') }],
      picListPink: [{ image: require('@/assets/images/pink.jpg') }],
      picListOrange: [{ image: require('@/assets/images/orange.jpg') }],
      current: '',
      clientHeight: 0,
      loadingExist: false,
    };
  },
  computed: {
    ...mapState('admin/layout', ['isMobile']),
    labelWidth() {
      return this.isMobile ? undefined : '110px';
    },
    labelPosition() {
      return this.isMobile ? 'top' : 'right';
    },
  },
  created() {
    this.picList = this.picListBule;
    this.getInfo();
  },
  mounted: function () {
    this.$nextTick(() => {
      this.clientHeight = `${document.documentElement.clientHeight}` - 250; //获取浏览器可视区域高度
      let that = this;
      window.onresize = function () {
        that.clientHeight = `${document.documentElement.clientHeight}` - 250;
      };
    });
  },
  methods: {
    selected(index) {
      this.current = index + 1;
      if (index == 0) {
        this.$set(this, 'picList', this.picListBule);
      } else if (index == 1) {
        this.$set(this, 'picList', this.picListGreen);
      } else if (index == 2) {
        this.$set(this, 'picList', this.picListRed);
      } else if (index == 3) {
        this.$set(this, 'picList', this.picListPink);
      } else if (index == 4) {
        this.$set(this, 'picList', this.picListOrange);
      }
    },
    getInfo() {
      getColorChange('color_change')
        .then((res) => {
          this.current = res.data.status ? res.data.status : 3;
          this.changeColor(this.current);
        })
        .catch((err) => {
          this.$message.error(err.msg);
        });
    },
    submit() {
      this.loadingExist = true;
      colorChange(this.current, 'color_change')
        .then((res) => {
          this.loadingExist = false;
          this.$message.success(res.msg);
        })
        .catch(() => {
          this.loadingExist = false;
        });
    },
    changeColor(e) {
      switch (e) {
        case 1:
          this.picList = this.picListBule;
          break;
        case 2:
          this.picList = this.picListGreen;
          break;
        case 3:
          this.picList = this.picListRed;
          break;
        case 4:
          this.picList = this.picListPink;
          break;
        case 5:
          this.picList = this.picListOrange;
          break;
        default:
          break;
      }
    },
  },
};
</script>

<style scoped lang="scss">
.box {
  width: 100px;
  text-align: center;
}

.bnt {
  // width 10px!important;
}

.pictrue {
  width: 800px;
  height: 100%;
  margin: 10px 24px 0 0;

  img {
    width: 100%;
    height: 100%;
  }
}

.footer {
  width: 100%;
  height: 70px;
  box-shadow: 0px -2px 4px rgba(0, 0, 0, 0.03);
  background-color: #fff;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 9;
}
.main_c {
  width: 25px;
  height: 25px;
  border-radius: 5px;
  text-align: center;
  line-height: 25px;
  font-size: 14px;
}
.tab_color {
  width: 114px;
  height: 45px;
  border: 1px solid #e5e5e5;
  margin-bottom: 10px;
  margin-right: 20px;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.color_cont {
  font-size: 14px;
}
.mr-2 {
  margin-right: 10px;
}
.color_bdg {
  display: block;
  width: 18px;
  height: 18px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
.blue {
  background-color: #1ca5e9;
}

.green {
  background-color: #42ca4d;
}

.red {
  background-color: #e93323;
}

.pink {
  background-color: #ff448f;
}

.orange {
  background-color: #fe5c2d;
}
.active {
  border: 1px solid var(--prev-color-primary);
}

::v-deep .ivu-radio-border {
  position: relative;
}

.iconfont {
  font-size: 12px;
  color: #fff;
}

::v-deep .ivu-radio-inner:after {
  background-color: unset;
  transform: unset;
}

::v-deep .i-layout-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
</style>
